草庐IT

c++ - 如何在 Lua 5.2.3 中将 lua_number 从 double 正确更改为 float

全部标签

ruby - 如何在 rake TestTask 失败后抑制巨大的堆栈跟踪?

我正在为一个项目设置一个rakefile,并且我已经定义了一些rakeTestTasks。我运行了一个简单的健全性测试,该测试执行assert_equal(1,2)只是为了检查输出,除了通常的失败输出之外,我还遇到了这样一团糟:rakeaborted!Commandfailedwithstatus(1):[/usr/bin/ruby-w-I"lib:.""/usr/lib/ruby/...]/usr/lib/ruby/1.9.1/rake.rb:993:in`blockinsh'/usr/lib/ruby/1.9.1/rake.rb:1008:in`call'/usr/lib/ruby

ruby - 如何在 Ruby 的循环中跳过几次迭代?

假设我有下面的C代码for(i=0;i如何转换为Ruby?我知道我们可以使用next跳过一次迭代,但我必须根据条件值跳过几次迭代,而且我不知道在运行时之前要跳过多少次迭代?这是我实际处理的代码(如Coreyward所述):我正在数组中寻找值相差小于0.1的“直线”(小于0.1将被视为“直线”)。范围必须大于50才能被视为长“线”。找到线范围[a,b]后,我想跳过迭代到上限b,这样它就不会从a+1重新开始,而是从b+1开始寻找新的“直线”for(i=0;i50){//Foundalinewithrangegreaterthan50,andstorethestartingpointtoli

ruby-on-rails - 如何在一台服务器上运行多个微型 Rub​​y (Rack) 应用程序?

我想在我的VPS上运行几个(超过2个)基于Rack的微型应用程序,而VPS已经运行了一个大型Rails应用程序。Rails应用程序使用传统的Unicorn和nginx组合,它需要我VPS上的大部分RAM。我尝试为每个应用程序添加类似的Unicorn配置,这让我得出结论,RAM不足。所以我的问题是:是否可以设置一个小型内存节省服务器,让我可以同时运行多个Sinatra应用程序?更新:以防万一,我不太关心性能。这些应用并非旨在执行任何严肃的工作。更新2:基于与Nginx共享的套接字的方法优于使用端口的方法。谢谢! 最佳答案 我对这个问题

ruby - 如何在 ruby 中使用钩子(Hook)

我有一个gem,它需要在安装gem后执行一些rake任务。使用http://blog.costan.us/2008/11/post-install-post-update-scripts-for.html中描述的方法在安装后执行代码有一种骇人听闻的方式。.但是Gem类现在有钩子(Hook),其中之一是post_install钩子(Hook)。我正在尝试添加一行Gem.post_install{puts'posthookexample'}进入Rakefile并且它似乎没有在安装过程中执行。这条线应该放在哪里才能注册钩子(Hook)? 最佳答案

ruby-on-rails - 如何在单独的文件中将模块包含到 rake 命名空间?

我有一个模块和一个子类。我在模块中拥有所有功能的地方。在子类中,我只是调用模块中的方法。我希望这个模块与命名空间下的rake任务链接,并且这两个文件在同一目录中。RAILS_ROOT/库。我该怎么做呢?我正在运行Rails3.0.3。 最佳答案 在lib/tasks/your_namespace.rake下创建一个文件,并写入任务:namespace:your_namespacedodesc"Anoptionaldescriptionofyourtask"task:your_task_name=>[:environment]do#y

c - 为什么此代码不适用于 ruby​​ 1.9 但适用于 ruby​​ 1.8?

我从ruby​​website下载了最新稳定的ruby​​源代码(1.9.2-p180)并使用MinGW4.5.2-TDM和MSYS在Windows上编译它。为了编译,我运行了shconfigure和make。我完全按照预期获得了msvcrt-ruby191.dll和libmsvcrt-ruby191.dll.a。然后我写了这段代码:#includeintmain(){ruby_init();rb_funcall2(Qnil,rb_intern("p"),1,(VALUE[]){INT2FIX(0)});ruby_finalize();}我用g++编译,链接到ruby​​的dll。当我

c - Data_wrap_struct 和标记函数

我正在编写一个Ruby扩展,我正在使用函数Data_wrap_struct。为了参与Ruby的标记和清除垃圾收集过程,我需要定义一个例程来释放我的结构,以及一个例程来标记从我的结构到其他结构的任何引用。我通过经典的free函数来释放内存,但我不知道如何使用标记函数。我的结构听起来像这样typedefstruct{intx;inty;}A;typedefstruct{Acollection[10];intcurrent;}B;我认为我需要一个标记函数来标记结构B的collection中的引用。谁能给我看一个例子,看看标记函数是如何工作的? 最佳答案

c - C 扩展中的 Ruby 关键字参数

如何处理来自C扩展的Ruby2.0.0关键字参数?背景defexample(name:'Bob'hat_color:'red')puts"#{name}hasa#{hat_color}hat!"endexample#=>"Bobhasaredhat!"example(name:'Joe',hat_color:'blue')#=>"Joehasabluehat!"关键字参数(如上)在处理具有许多不同调用序列或选项的方法时非常有用。我在C扩展中有一个这样的方法(一种处理我项目中大部分OpenGL绘图的blit方法),我想知道如何让该方法处理来自ruby​​的关键字参数。想法根据我所做的一些

ruby-on-rails - Ruby 1.9.1-p234、Passenger 2.2.5、Rails 2.3-stable 在 POST 请求时关闭流

我已经在Ubuntu服务器上安装了Ruby1.9.1(p234)。我正在尝试在Apache2.2/Passenger2.2.5上部署一个供应商Rails2.3-stable的Rails应用程序。GET请求工作正常,POST请求立即中断并显示以下日志条目:ProcessingUsersController#new(for80.203.77.44at2009-10-2420:54:55)[GET]Parameters:{"controller"=>"users","action"=>"new"}Renderingtemplatewithinlayouts/applicationRender

ruby - 如何在 Ruby 中深度复制 Proc?

在Ruby中是否有直接的方法来生成Proc的副本?我有一个名为@foo的Proc。我想要另一种方法来定期增加@foo的附加逻辑。例如:#createinitialProc@foo=lambda{|x|x}#augmentwithmorelogic@foo=lambda{|x|x>1?x*x:@foo[x]}我不希望进行扩充的第二行生成递归函数。相反,我希望@foo按值绑定(bind)到新的@foo定义的词法范围内,生成一个看起来更像这样的函数:@foo=lambda{|x|x>1?x*x:lambda{|x|x}[x]}由于生成的函数如下所示,我得到了无限递归和最终的堆栈溢出:@foo